# DIGITAL DESIGN

LAB9 SYNCHRONOUS SEQUENTIAL CIRCUIT-LATCH-FLIPFLOP

### LAB9

- Synchronous sequential circuit
  - Latch
  - Flip Flops (key point of lab9)
- Verilog
  - always@(posedge clk) , always@(negedge clk) vs always@\*
  - blocking assignment vs non-blocking assignment
- Practice

#### RECALL: 4-2 PRIORITY-EN-CODER

```
1/4-2 priority-encoder
module pri_encoder(
input I0, I1, I2, I3,
output reg [1:0] Y
    always @ begin
        casex( {I3, I2, I1, I0})
            4' bxxx0: Y=2' b00:
            4' bxx01: Y=2' b01:
            4' bx011: Y=2' b10:
            4' b0111: Y=2' b11:
        endcase
    end
endmodule
```





If there is no 'default' branch and the branch(e.g. 4'b1111 in this demo) is not list in the branches of the 'case', the circuit state will remain

unchanged, and then a latch will be generated to save the state.

#### LATCH

- The schematic on the right hand is the schematic of the synthesized design generated by vivado.
- Data Latch with
  Asynchronous Clear
  and Gate Enable



For more information on LDCE, please refer to Xilinx 7 Series FPGA Libraries Guide for Schematic Design

#### D LATCH

• Latch: the simplest binary memory elements, static device composed of gates. When the input changes, the output changes immediately.



```
module D_Latch(
input En, D,
output reg Q,
output vire nQ
);
assign nQ = ~Q;
always @*
if(En)
Q = D;
else
Q = Q;
endmodule
```

### D LATCH

Schematic of RTL analysis:

| En D              | Next state of Q                                     |
|-------------------|-----------------------------------------------------|
| 0 X<br>1 0<br>1 1 | No change $Q = 0$ ; reset state $Q = 1$ ; set state |



Simulation result of D Latch



## FLIP FLOP ( DESIGN )

- The storage elements (memory) used in clocked sequential circuits are called flipflops.
- The most economical and efficient flip-flop constructed is the edge-triggered D flipflop, because it requires the smallest number of gates.



Figure for master-slave positive-edge triggered **D flip-flop** 

```
module D_ff_p_from_latch(
input clk, D,
output Q
);
/*module D_latch(input En,D,
output reg Q, output nQ);*/
wire P, nq_master, nq_slaver;
D_latch ud_master(~clk, D, P,nq_master);
D_latch ud_slaver(clk, P, Q, nq_slaver);
endmodule
```

## FLIP FLOP (TESTBENCH, WAVEFORM)

master-slave positive-edge triggered D flip-flop



```
module D_ff_p_from_latch(
input clk, D,
output Q
);
/*module D_latch( input En,D,
output reg Q, output nQ );*/
wire P, nq_master, nq_slaver;
D_latch ud_master(~clk, D, P,nq_master);
D_latch ud_slaver(clk, P, Q, nq_slaver);
endmodule
```



```
module D ff p tb( );
/*module D_ff_p_from_latch(input clk, D, output Q ); */
reg sclk, sD;
wire sQ:
D ff p from latch dut1(sclk, sD, sQ);
initial begin
sclk=1'b0;
forever #10 sclk = ~sclk:
end
initial fork
sD = 1'b0:
#15 sD = 1'b1;
#35 sD = 1'b0;
#60 $finish:
ioin
endmodule
```

### D FLIP FLOP

| Clk      | Q         |
|----------|-----------|
| <b>^</b> | D         |
| 0        | no change |
| 1        | no change |
| 4        | no change |

Here is **positive-edge** triggered D flip-flop

```
module D_flipflop(
input clk, D,
output reg Q,
output nQ
);
always @(posedge clk)
Q <= D;
assign nQ = ~Q;
endmodule
```



## PRACTICE(1)

- Implement a negative-edge triggered D flipflop
  - a) by using two D latch
  - b) using behavior manner



- Build a testbench to test the negative-edge triggered D flipflop, do the simulation.
  - the expected waveform of the negative-edge triggered D flipflop is shown in the following figure.



## JK FLIP FLOP(1)

$$\bullet \ Q^{n+1} = J\overline{Q^n} + \overline{K}Q^n$$

| J | К | Qn+1      |
|---|---|-----------|
| 0 | 0 | no change |
| 0 | 1 | 0         |
| 1 | 0 | 1         |
| 1 | 1 | Qn'       |





## JK FLIP FLOP(2) $Q^{n+1} = J\overline{Q^n} + \overline{K}Q^n$

$$Q^{n+1} = J\overline{Q^n} + \overline{K}Q^n$$

```
module J_K_Flip_Flop(
    input Clk, J, K,
    output reg Q,
    output nQ
    assign nQ = ~Q;
    always @ (posedge Clk)
        case ({J, K})
             2' b10: Q <= 1' b1; //set
             2' b01: Q<= 1' b0; //reset
             2' b11: Q <= nQ; //reverse
             2'b00: Q<= Q; //keep
        endcase
endmodule
```

| J | К | Qn+1      |
|---|---|-----------|
| 0 | 0 | no change |
| 0 | 1 | 0         |
| 1 | 0 | 1         |
| 1 | 1 | Qn'       |

| Name   | Value | 0 ns | 5.000 ns | 10 ns | 15, 000 r | 20 ns | 25. 000 ns | ns . | 5. 000 n | 40 ns | 45,000 ns | 50 ns |
|--------|-------|------|----------|-------|-----------|-------|------------|------|----------|-------|-----------|-------|
| ™ sClk | 0     |      |          |       |           |       |            |      |          |       |           |       |
| ™ sJ   | 0     | 0    |          | 0     |           | 1     |            | 1    |          | 0     |           |       |
| ™ sK   | 1     | 0    |          | 1     | 1         | 0     |            | 1    |          | 0     |           |       |
| ₩ sQ   | 0     | ke   | ер       | res   | et        | se    | t r        | ever | rse      | ke    | ер        |       |
| ₩ snQ  | 1     | -    |          |       |           |       |            |      |          |       |           |       |
|        |       |      |          |       |           |       |            |      |          |       |           |       |

### USING JK FLIP FLOP TO IMPLEMENT D FLIP FLOP

- JK Flip-Flop:  $Q^{n+1} = J\overline{Q^n} + \overline{K}Q^n$
- D Flip-Flop:  $Q^{n+1} = D = D\overline{Q^n} + DQ^n$

| J | K | Qn+1      |
|---|---|-----------|
| 0 | 0 | no change |
| 0 | 1 | 0         |
| 1 | 0 | 1         |
| 1 | 1 | Qn'       |

| Clk      | Q         |
|----------|-----------|
| <b>^</b> | D         |
| 0        | no change |
| 1        | no change |
| <b>4</b> | no change |

```
module Dff_byJKff(
input clk, D,
output Q, nQ
);

J_K_Flip_Flop u(clk, D, ~D, Q, nQ);
endmodule
```



### T FLIP FLOP

• The *T* (toggle) flip-flop is a complementing flip-flop.



| Т | Qn+1 |
|---|------|
| 0 | Q°   |
| 1 | ~Qr  |

```
module T_Flip_Flop(
input Clk, T,
output reg Q,
output nQ
    assign nQ = Q;
    always @(posedge Clk)
        case(T)
            1' b1: Q<= ~Q;
            1' b0: Q<= Q;
        endcase
endmodule
```

### USING JK FLIP FLOP TO IMPLEMENT T FLIP FLOP

• The *T* (toggle) can be obtained from a *JK* flip-flop when inputs *J* and *K* are tied together.



| T | Qn+1           |
|---|----------------|
| 0 | Q <sup>n</sup> |
| 1 | ~Qr            |

| J | К | Qn+1      |
|---|---|-----------|
| 0 | 0 | no change |
| 0 | 1 | 0         |
| 1 | 0 | 1         |
| 1 | 1 | Qn'       |





### WIRE VS REG(1)

- There are two data types in Verilog: wire and register.
  - wire is a kind of net, which is equivalent to physical connection.
  - wire is used to connects two points, and thus does not have any driving strength
  - wire data types can be used for connecting the output port to the actual driver
  - a wire can be assigned a value by a continuous assign statement, which is used for designing combinational logic
  - default data type is wire: this means that if you declare a port or variable without specifying reg or wire, it will be a 1-bit wide wire.
  - reg is a kind of register, which is equivalent to memory cell.
  - reg can store value and drive strength. Reg can be used for modeling both combinational and sequential logic.
  - reg data type can be driven from initial and always block.
  - The LHS of a behavioral block(initial, always) should be declared as reg
  - input port could drive by both wire/register, but it could ONLY be declared as wire
  - output port can be declared as wire or register, but it can ONLY drive wire
  - Voidinactional quantities and only be declared as wire

#### NON-BLOCKING ASSIGNMENT VS BLOCKING ASSIGNMENT

- The '=' token represents a blocking procedural assignment
- A combinational logic always block should use Blocking assignments("=").
- The '<=' token represents a non-blocking procedural assignment
- A sequential logic always block should use Non-blocking assignments ("<=").

NOTE: **DO NOT** mixing blocking assignment and non-blocking assignment in the same always block !!!

## PRACTICE(2)

- Try to construct a T flipflop with a reset input.
  - There would be a reset input port apart from other inputs(clk, T), while it enable the output of T flipflop is 1'b0, while it disable the circuit works as T flipflop
  - Do the design and verify the function of your design.
  - Create the constraint file, do the synthetic and implementation, generate the bitstream file and program the device, then test on the minisys develop board.

### PRACTICES(3)

$$Q^{n+1} = J\overline{Q^n} + \overline{K}Q^n$$

- Can this JK flip-flop work?
- Try to use it implement a T flip-flop, do the design, create constraint file, generate the bitstream file and program the device.
- Can the T flip-flop work? Explain the reason.

```
module J_K_Flip_Flop(
    input Clk, J, K,
    output reg Q, Qn
    always @(posedge Clk)
        if({J, K} = 2'b10)//set
        begin
            {Q, Qn} <= 2' b10:
        end
        else if ({J, K}=2'b01)//reset
        begin
            \{Q, Qn\} = 2'b01:
        end
        else if({J, K} = 2'b11)//reverse
        begin
            0 (= Qn:
            On <= 0:
        end
endmodule
```

#### TIPS:

Constraints: if you want to use IO pin as clock, you should use the
 CLOCK\_DEDICATED\_ROUTE FALSE constraint in the .xdc file to demote the Error message to a (Critical) WARNING. NOTES: This (Critical) WARNING HERE could be ignored.

```
set_property IOSTANDARD LVCMOS33 [get_ports clk]
set_property IOSTANDARD LVCMOS33 [get_ports D]
set_property IOSTANDARD LVCMOS33 [get_ports Q]
set_property IOSTANDARD LVCMOS33 [get_ports Qn]
set_property PACKAGE_PIN P5 [get_ports clk]
set_property PACKAGE_PIN R1 [get_ports D]
set_property PACKAGE_PIN J2 [get_ports Q]
set_property PACKAGE_PIN K2 [get_ports Qn]
set_property CLOCK_DEDICATED_ROUTE_FALSE [get_nets {clk_IBUF}]
```